package com.fowo.api.model.position.flow1;

import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.fowo.api.common.validator.*;
import io.swagger.v3.oas.annotations.media.Schema;
import javax.validation.constraints.*;
import lombok.Getter;
import lombok.Setter;

/**
 * 仓位流水1 预览导入辅助模型(全字段为文本类型)
 * @author yl_ls
 */
@Getter
@Setter
public class PositionFlow1ImportPo {

  /** 生产日期 */
  @ExcelProperty("生产日期")
  @DateString(message = "生产日期不是有效的日期格式")
  private String productionDate;

  /** 操作时间 */
  @ExcelProperty("操作时间")
  @DateString(message = "操作时间不是有效的日期格式")
  private String operateTime;

  /** 类型 */
  @ExcelProperty("*类型")
  @NotBlank(message = "类型不能为空")
  private String type;

  /** 单据号 */
  @ExcelProperty("单据号")
  @Size(max = 50, message = "单据号长度不能超过50")
  private String countnum;

  /** 品名 */
  @ExcelProperty("品名")
  @Size(max = 500, message = "品名长度不能超过500")
  private String itemIdName;

  @ExcelIgnore
  @Schema(title = "品名")
  private String itemId;

  /** 关联单据号 */
  @ExcelProperty("关联单据号")
  @Size(max = 50, message = "关联单据号长度不能超过50")
  private String formNum;

  /** SKU */
  @ExcelProperty("SKU")
  @Size(max = 50, message = "SKU长度不能超过50")
  private String sku;

  /** FNSKU */
  @ExcelProperty("FNSKU")
  @Size(max = 50, message = "FNSKU长度不能超过50")
  private String fnSku;

  /** 店铺 */
  @ExcelProperty("店铺")
  @Size(max = 50, message = "店铺长度不能超过50")
  private String shopIdShopName;

  @ExcelIgnore
  @Schema(title = "店铺")
  private String shopId;

  /** 仓库 */
  @ExcelProperty("仓库")
  @Size(max = 50, message = "仓库长度不能超过50")
  private String stockIdName;

  @ExcelIgnore
  @Schema(title = "仓库")
  private String stockId;

  /** 仓位 */
  @ExcelProperty("仓位")
  @Size(max = 50, message = "仓位长度不能超过50")
  private String binIdStorageBin;

  @ExcelIgnore
  @Schema(title = "仓位")
  private String binId;

  /** 锁库数量 */
  @ExcelProperty("锁库数量")
  @DecimalString(message = "锁库数量小数格式不正确", label = "锁库数量")
  private String lockQty;

  /** 在途数量 */
  @ExcelProperty("在途数量")
  @DecimalString(message = "在途数量小数格式不正确", label = "在途数量")
  private String wayQty;

  /** 库存数量 */
  @ExcelProperty("库存数量")
  @DecimalString(message = "库存数量小数格式不正确", label = "库存数量")
  private String stockQty;

  /** 名称 */
  @ExcelProperty("名称")
  @Size(max = 50, message = "名称长度不能超过50")
  private String name;

  /** 操作业务名称 */
  @ExcelProperty("操作业务名称")
  @Size(max = 50, message = "操作业务名称长度不能超过50")
  private String operate;

  /** 关联唯一操作键 */
  @ExcelProperty("关联唯一操作键")
  @Size(max = 50, message = "关联唯一操作键长度不能超过50")
  private String operateKey;

  /** 项目内码 */
  @ExcelProperty("项目内码")
  @LongString(message = "项目内码数值格式不正确", label = "项目内码")
  private String projectId;

  /** 保质期(天) */
  @ExcelProperty("保质期(天)")
  @LongString(message = "保质期(天)数值格式不正确", label = "保质期(天)")
  private String shelfLife;

  /** 变动目标类型 */
  @ExcelProperty("变动目标类型")
  @Size(max = 50, message = "变动目标类型长度不能超过50")
  private String toType;

  /** 批号 */
  @ExcelProperty("批号")
  @Size(max = 50, message = "批号长度不能超过50")
  private String batchNo;

  /** 变动源类型 */
  @ExcelProperty("变动源类型")
  @Size(max = 50, message = "变动源类型长度不能超过50")
  private String fromType;

  /** 关联制单人 */
  @ExcelProperty("关联制单人")
  @Size(max = 50, message = "关联制单人长度不能超过50")
  private String formOperator;

  /** 有效期至 */
  @ExcelProperty("有效期至")
  @DateString(message = "有效期至不是有效的日期格式")
  private String expiryDate;

  /** 描述 */
  @ExcelProperty("描述")
  private String description;

  /** 在途数量变更 */
  @ExcelProperty("在途数量变更")
  @DecimalString(message = "在途数量变更小数格式不正确", label = "在途数量变更")
  private String changeWayQty;

  /** 变动类型 */
  @ExcelProperty("变动类型")
  @Size(max = 50, message = "变动类型长度不能超过50")
  private String changeType;

  /** 库存数量变更 */
  @ExcelProperty("库存数量变更")
  @DecimalString(message = "库存数量变更小数格式不正确", label = "库存数量变更")
  private String changeStockQty;

  /** 锁库数量变更 */
  @ExcelProperty("锁库数量变更")
  @DecimalString(message = "锁库数量变更小数格式不正确", label = "锁库数量变更")
  private String changeLockQty;

  /** 仓库属性 */
  @ExcelProperty("仓库属性")
  @Size(max = 50, message = "仓库属性长度不能超过50")
  private String wareattributeName;

  @ExcelIgnore
  @Schema(title = "仓库属性")
  private String wareattribute;

  /** 备注 */
  @ExcelProperty("备注")
  @Size(max = 50, message = "备注长度不能超过50")
  private String reamark;
}
